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DYNAMIC COMMAND SETS IN A COMPUTER MESSAGING SYSTEM 
IN A METHOD, SYSTEM AND PROGRAM 

BACKGROUND OP THE INVENTION 

1. Technical Field; 

The present invention generally relates to distributed 
data processing systems and in particular to client -server data 
processing systems. Still more particularly, the present 
invention relates to command sets in a computer messaging 
system. Further, the present invention relates to modification 
of command sets on a server in a computer network. 

2. Description of the Related Art: 

In the area of client -server computing, many computers 
interact over a computer network through messaging systems. 
Messages containing code define commands that a client may 
issue to the server computer to perform tasks on the server, 
such as accessing databases, starting a process, sorting search 
results, connecting to other computers, retrieving email, etc. 

Typically, function codes and parameters are encoded in 
application-specific form. Frequently, the encoding process 
arranges function codes in a fixed order and with a fixed 
offset from the beginning of a message. The meaning of the 
function code and the interpretation of parameters is known 
only by the sending and receiving applications. As new 
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releases of applications are prepared, encoding schemes used 
for function codes may vary. Updating sending and receiving 
(messaging) applications thus can become a continuous and 
complex task - especially in widely distributed systems. 

5 

Whether done by client or server, often there is a 
function that converts ''gestures" or other input into these 
messages. This function is commonly known as a dispatch table 
or a command interpreter. An example of such a command 
10 interpreter function in the Java programming language is given 

in Table 1. 



public SimpleCmd readCommand ( ) throws IOException{ 
SimpleCmd cdm; 

String commandNatne - readNameO; 

if ( commandName. equal sIgnoreCase { "AddCmd" ) ) { 

cmd = new AddCmd ( ) ; 
} else if { commandName. equals Ignore Case ( "DeleteCmd" ) ) { 

cmd = new DeletCmd{) / 
} else if { commandName. equals I gnor eCa se ( "GetCmd" ) ){ 

cmd = new GetCmd {) ; 
} else if ( commandName. equalsIgnoreCase ( "PostCmd" ) ) { 

cmd = new PostCmd (); 
} else if (commandName. equalsIgnoreCase ( "DoneCmd" ) ) { 

cmd = new DoneCmd ( ) / 
} else 

throw new IOException( "unknown command " + commandName ) ; 
cmd- setArgs { readArgs () ) ; 

return cmd; 



TABLE 1 



15 The purpose of this function is to take a command name. 
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given as a string, and find and instantiate a command object 
that will perform the command. The drawback to this type of 
dispatch table is the hard-coded nature of the command set. 
This example tests for five commands, but any commands that are 
not explicitly coded in the function are ignored and an error 
condition is signaled. If ever the system needed an additional 
command, the client or the server would have to be halted while 
new code is installed on the system. 

There are other messaging systems that refer to commands 
by number rather than a name to reduce traffic congestion. 
This saves more network bandwidth than sending the command 
name, but the same problems of static rather than dynamic 
tables exist. Another type of messaging system creates a 
command on the client side and sends the entire command object 
to the server. This is known as command serialization or 
command marshalling/unmarshalling, and can tax network 
bandwidth . 

There are a variety of situations in which it would be 
preferable not to halt the system to install new object code 
for the command interpreter or dispatch table. Most common are 
commercial sales applications on the Internet, which may 
experience heavy, round-the-clock traffic. Taking a sales 
application off-line for an upgrade may result in lost revenue 
due to customer disaffection. 

It would therefore be desirable to provide a method and 
system that would allow new commands to be installed without 
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pausing either the client or server computer. Also, it would 
be desirable to enlarge or reduce a command set without 
recompiling the code that contains the dispatch table. 
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SUMMARY OP THE INVENTION 

It is therefore one object of the present invention to 
enlarge or reduce a command set without pausing a server 
computer. 

It is another object of the present invention to provide a 
method that will enlarge or reduce a command set without 
pausing a client computer and without recompiling code that 
contains a dispatch table. 

The foregoing objects are achieved as is now described. 
Rather than using a command interpreter or dispatch table, 
commands within a messaging system are given a name which 
matches the filename for the class file implementing the 
command. A command name, or command number, may be 
subsequently passed to a server in a messaging system and used 
to dynamically load and instantiate a message command by 
loading a class of the same name. Additional command classes 
may therefore be added or deleted, at runtime, from client or 
server code without halting the application. An error 
condition is signaled when the command name is unrecognized, 
when the command code is unavailable or when there are problems 
instantiating an instance of the command class. Once the class 
code is loaded, a new instance of the class is created and the 
command object may be utilized. 

The above as well as additional objectives, features, and 
advantages of the present invention will become apparent in the 
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following detailed written description. 
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BRIEF DESCRIPTION OF THE DRAWINGS 



The novel features believed characteristic of the 
invention are set forth in the appended claims. The invention 
5 itself however, as well as a preferred mode of use, further 

objects and advantages thereof, will best be understood by 
reference to the following detailed description of an 
illustrative embodiment when read in conjunction with the 
accompanying drawings, wherein: 

10 

Figure 1 depicts a high-level block diagram of a data 
processing system network in which a preferred embodiment of 
the present invention may be implemented; 



15 Figures 2A-2B are high-level flow diagrams for processes 

of providing dynamic command sets in a computer messaging 
system and updating the system with new commands in accordance 
with a preferred embodiment of the present invention; and 

20 Figure 3 depicts an example of pseudo-code in the Java 

programming language for employing commands which may be 
dynamically updated at run-time in accordance with a preferred 
embodiment of the present invention. 
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DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENT 



With reference now to the figures, and in particular with 
reference to Figure 1, a high-level block diagram of a data 
5 processing system network in which a preferred embodiment of 

the present invention may be implemented is depicted. Data 
processing system network 102 includes one or more servers 104- 
106 which are accessible as part of the Internet 108 or other 
network. Data processing system network 102 also includes one 

10 or more clients 110-112 which may access or receive content 

from servers 104-106. The content may be accessed using any of 
a variety of messaging system protocols including HyperText 
Transfer Protocol (HTTP) , File Transfer Protocol (FTP) , Network 
News Transfer Protocol (NNTP) , Internet Mail Access Protocol 

15 (IMAP) or Post Office Protocol (POP) . 



In accordance with the present invention, a client within 
data processing system network 102, such as client 112, 
includes a messaging system client application 114 (e.g., a 

20 browser) capable of transmitting messages containing commands 

to a messaging system server application 116 within a server, 
such as server 106, within data processing system network 102. 
The commands are issued by client application 114 to server 
application 116 in order to cause some operation to be 

25 performed by server 106. 

In object oriented programs, such as Java programs, 
commands are typically generated by clients and issued to a 
server via a messaging system. A function on the client or 
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server known as a dispatch table or a command interpreter is 
utilized to take a command and instantiate a command object to 
ultimately perform the command. If a particular command is not 
coded in the table or interpreter, the command is ignored and 
5 an error condition is signaled. The structures of prior art 

systems prevent commands, that are not already loaded on the 
system, from being issued. If a system needed an additional 
command object, the client or server would have to be halted 
while new code is installed on the server. 

10 

The present invention allows dynamic addition of commands, 
by loading of new class files, without requiring a system halt 
or recompiling of a dispatch table. The messaging system of 
the present invention utilizes commands which have the same 

15 name as the filename for the class file containing the source 

code implementing the command, excluding the filename extension 
(e.g., ".java"). Thus, for example the command '^commandName" 
corresponds to, and is implemented by source code within, the 
class file ''commandName . java" . Command names are transmitted 

20 within messages from, for instance, client application 114 to 

server application 116. The command set supported by either 
client 114 or server 116, which is defined by the common set of 
command class files 118 within both systems, may be updated 
dynamically, without halting the messaging system or 

25 application. Rather than shutting down the system, the present 

invention provides for loading a class file for the new command 
object at runtime with no need for shutting down the system. A 
class file for the new command may then be transmitted to the 
client and/or server. A command object may be instantiated 
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from the class file as necessary, thus eliminating system 
downtime for a new command. 

Referring now to Figures 2A-2B, high-level flow diagrams 
5 for processes of providing dynamic command sets in a computer 

messaging system in accordance with a preferred embodiment of 
the present invention are illustrated. Figure 2A illustrates a 
process for employing commands within a message system in 
accordance with the present invention. The process begins with 

10 step 202, which depicts a command name being sent, via a 

messaging system, to a server to be used to load a class of the 
same name {except for the filename extension) . In Java, 
employed in the exemplary embodiment of the present invention, 
and in several other computer languages, a ClassLoader is used 

15 to load classes dynamically at run time. Once the class code is 

loaded, a new instance of the class may be created and the 
command implemented by the class may be executed. An error 
condition is signaled if the command name is not recognized. 

20 The process thus passes to step 204, which illustrates 

extracting the command name from the message transmitted from 
the client to the server within the messaging system, and then 
to step 206, which depicts a determination of whether the 
command name is recognized by the system (i.e., whether a class 

25 file having a matching name can be located) , If the command 

name is not recognized^ the process proceeds to step 208, which 
illustrates the system throwing a error signal. New class 
files may then be dynamically loaded from a predesignated 
source to accommodate the new command. 
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Returning to step 206, if the command name is recognized 
(found to match a class filename, except for the extension) , 
the process proceeds instead to step 210, which depicts a 
determination of whether the class file source code is 
5 available. If the class file source code corresponding to the 

transmitted command name is not available, the process proceeds 
to step 208, which depicts the system throwing an error. 
Again, source code for the required class file may optionally 
be downloaded from a predesignated source. 

10 

If the class file source code is available, the process 
proceeds instead to step 212, which illustrates instantiating 
the class file corresponding to the command, and then to step 
214, which depicts a determination of whether any problems 

15 occurred during instantiation of the class. If so, the process 

proceeds to step 208, which illustrates the system throwing an 
error. Otherwise, the process proceeds instead to step 216, 
which depicts executing the command. From either of steps 20 8 
or 216, the process passes to step 218, which illustrates the 

20 process becoming idle until another command is received via the 

messaging system. 



Figure 2B illustrates a process for updating the messaging 
system with new commands in accordance with the present 
25 invention. The process begins with step 22 0, which depicts an 

update of the command set being initiated. The process first 
passes to step 222, which illustrates copying new class files 
for the new command to the client and server or deleting class 
files for discontinued commands from the client and server. 
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then to step 224, which depicts loading the new class files 
within the server. This occurs at runtime, with additional 
command classes being added to or removed from the client or 
server code without recompiling any code for a command 
interpreter or dispatch table. The process then passes to step 
226, which illustrates the process becoming idle until another 
update is initiated. 

Referring now to Figure 3, an example of pseudo-code in 
the Java programming language for employing commands which may 
be dynamically updated at run-time in accordance with a 
preferred embodiment of the present invention is depicted. In 
the pseudo-code, ' commandName ' is used to load a class of the 
same name. The command name that is passed in the message 
system is used to dynamically load and instantiate the message 
command. Once the class code is loaded, a new instance of the 
class is created. If 'commandName' is unrecognized, an error 
condition is signaled. A similar error is generated if 
' commandName' is unavailable on the system. However, in the 
present invention, the dispatch table is not necessary^ nor is 
halting the system, as command classes are loaded dynamically 
in client or server code. 

The present invention has several advantages. Commands 
may be added or deleted at runtime without recompiling code.. 
Command classes may be added or removed, dynamically, in the 
client or server code. Maintenance costs are lessened and code 
is less prone to error when introducing new commands. There is 
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no dispatch table to recompile, nor is there a command list to 
maintain. 

Also, the present invention has an additional advantage in 
5 that sending a command name over a network requires fewer bytes 

than sending an entire serialized class. Other messaging 
systems refer to commands by number rather than name. Dynamic 
command sets, in the present invention, may also refer to each 
command by number by returning a command identification number 
10 to the client for future use. 

It is important to note that while the present invention 
has been described in the context of a fully functional data 
processing system and/or network, those skilled in the art will 

15 appreciate that the mechanism of the present invention is 

capable of being distributed in the form of a computer usable 
medium of instructions in a variety of forms, and that the 
present invention applies equally regardless of the particular 
type of signal bearing medium used to actually carry out the 

20 distribution. Examples of computer usable mediums include: 

nonvolatile, hard-coded type mediums such as read only memories 
(ROMs) or erasable, electrically programmable read only 
memories (EEPROMs) , recordable type mediums such as floppy 
disks, hard disk drives and CD-ROMs, and transmission type 

25 mediums such as digital and analog communication links. 

While the invention has been particularly shown and 
described with reference to a preferred embodiment, it will be 
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understood by those skilled in the art that various changes in 
form and detail may be made therein without departing from the 
spirit and scope of the invention. 
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CLAIMS : 

What is claimed is: 



1 1, A method for generating a command in a computer messaging 

2 system, comprising the steps of: 

3 receiving a command name into a server via said messaging 

4 system; and 

5 utilizing said command name to automatically load a class 

6 file having a name including said command name. 

1 2. The method of claim 1, further comprising: 

2 comparing said command name to existing classes on said 

3 server; 

4 creating a new instance of said class; and 

5 executing said new instance of said class, 

1 3, The method of claim 1, further comprising: 

2 deleting a current command at runtime. 

1 4. The method of claim 1, further comprising: 

2 adding a new command at runtime. 
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1 5. A method for employing a command in a messaging system, 

2 comprising the steps of: 

3 selecting a command to be executed; and 

4 transmitting, within a message to a system in which the 

5 selected command is to be executed, a command name for the 

6 selected command which matches a portion of a class filename 

7 for a class implementing the selected command. 

1 6. The method of claim 1, transmitting said command name for 

2 said selected command which matches a portion of a class 

3 filename for a class implementing the selected command, further 

4 comprises: 

5 comparing said command name to existing classes on said 

6 system; 

7 creating a new instance of said class; and 

8 executing said new instance of said class. 
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1 7. A method for employing a command in a computer network, 

2 comprising: 

3 receiving a message containing a command name; and 

4 locating a class file having a class filename including 

5 said command name; and 

6 loading and instantiating said class file. 



1 8. The method of claim 7, further comprising: 

2 comparing said command name to existing said class files; 

3 executing a new instance of said class. 
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1 9. A system for generating a command, comprising: 

2 selection means for selecting a command to be executed 

3 within a computer network; 

4 transmission means for sending a command name, within a 

5 message, for said selected command which matches a portion of a 

6 class filename for a class implementing said selected command. 

1 10. The system of claim 9, further comprising: 

2 means for comparing said command name to existing classes; 

3 means for loading said class file having said command 

4 name ; 

5 means for creating a new instance of said class; and 

6 execution means for executing said new instance of said 

7 class. 

1 11. The system of claim 9, further comprising: 

2 means for adding a new command at runtime. 

1 12. The system of claim 9, further comprising: 

2 means for deleting a current command at runtime. 
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1 13 . A system for employing a command via a messaging system, 

2 comprising: 

3 means for receiving a command name into a server via said 

4 messaging system; and 

5 means for utilizing said command to automatically load a 

6 class file having a name including said command name. 

1 14. The system of claim 13, further comprising: 

2 means for comparing said command name to existing classes; 

3 means for creating a new instance of said class; and 

4 execution means for executing said new instance of said 

5 class. 

1 15. The system of claim 13, further comprising: 

2 means for adding a new command at runtime, 

1 16. The system of claim 13, further comprising: 

2 means for deleting a current command at runtime. 
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1 17, A computer program product within a computer readable 

2 medium having instructions for generating a command, 

3 comprising: 

4 instructions within said computer program product for 

5 receiving a command name from a client computer via a messaging 

6 system; and 

7 instructions within said computer program product for 

8 utilizing said command name to automatically load a class file 

9 having a name including said command name. 

1 18, The computer program product of claim 17, further 

2 comprising: 

3 instructions within said computer program product for 

4 comparing said command name to existing classes on said server; 

5 instructions within said computer program product for 

6 creating a new instance of said class; and 

7 instructions within said computer program product for 

8 executing said new instance of said class. 

1 19. The computer program product of claim 17, further 

2 comprising: 

3 instructions within said computer program product for 

4 adding a new command at runtime, 

1 20, The computer program product of claim 17, further 

2 comprising: 

3 instructions within said computer program product for 

4 deleting a current command at runtime. 
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1 21. The computer program product of claim 17, further 

2 comprising: 

3 instructions within said computer program product for 

4 comparing said command name to existing classes on said server. 
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1 22 . A computer program product within a computer readable 

2 medium having instructions for employing a command in a 

3 messaging system, comprising: 

4 instructions within said computer program product for 

5 selecting a command to be executed; and 

6 instructions within said computer program product for 

7 transmitting, within a message to a system in which the 

8 selected command is to be executed, a command name for the 

9 selected command which matches a portion of a class filename 
10 for a class implementing the selected command, 

1 23. The computer program product of claim 22, further 

2 comprising: 

3 instructions within said computer program product for 

4 comparing said command name to existing classes on said server 

5 instructions within said computer program product for 

6 loading said class file having said command name; 

7 instructions within said computer program product for 

8 creating a new instance of said class; and 

9 instructions within said computer program product for 
10 executing said new instance of said class, 

1 24. The computer program product of claim 22, further 

2 comprising: 

3 instructions within said computer program product for 

4 deleting a current command at runtime. 
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DYNAMIC COMMAND SETS IN A COMPUTER MESSAGING SYSTEM 
IN A METHOD, SYSTEM AND PROGRAM 

ABSTRACT OF THE DISCLOSURE 

Rather than using a command interpreter or dispatch table, 
commands within a messaging system are given a name which 
matches the filename for the class file implementing the 
command, A command name, or command number, may be 
subsequently passed to a server in a messaging system and used 
to dynamically load and instantiate a message command by 
loading a class of the same name. Additional command classes 
may therefore be added or deleted, at runtime, from client or 
server code without halting the application. An error 
condition is signaled when the command name is unrecognized, 
when the command code is unavailable or when there are problems 
instantiating an instance of the command class. Once the class 
code is loaded, a new instance of the class is created and the 
command object may be utilized. 
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public SimpleCmd readCommandO throws lOException { 
String commandName = readName(); 
try{ 

Class cmdClass = classloader.loadClass( commandName);// 
ClassNotFoundException 

SimpleCmd cmd = (SimpleCmd) cmdClass.Newlnstance();// 

Cms.setArgs{ readArgs() ); 

return cmd; 
} catch (Exception e) } 

throw new IOException( "unknown command" + commandName); 
} /*endcatch*/ 
} 
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39,969; James H. Barksdale, Jr. Reg. No. 24,091; Anthony V. England, Reg. No. 
35,129; Leslie A. Van Leeuwen, Reg. No. 42,196; Christopher A. Hughes, Reg. No. 
26,914; Edward A. Pennington, Reg. No. 32, 588; John E. Hoel, Reg. No. 26,279; and 
Joseph C. Redmond, Jr., Reg. No. 18,753; Marilyn S. Dawkins, Reg. 31,140; Andrew 
Mitchell Harris, Reg. No. 42,638; Richard N. McCain, Reg. No. 43,785; Andrew J. 
Dillon, Reg. No. 29,634; Max Ciccarelli, Reg. No. 39,454; Jack V. Musgrove, Reg. 
No. 31,986; Daniel E. Venglarik, Reg. No. 39,409; Brian F. Russell, Reg. No. 
40,796; John G . Graham, Reg. No. 19,563; Matthew W. Baca, Reg. No. 42,277; Justin 
M. Dillon, Reg. No. 42,486; Antony P. Ng, Reg. No. 43,427; Steven Lin, Reg. No. 
3 5,250; Matthew S. Anderson, Reg. No. 3 9,093; Sidney L. Weatherford, Reg. No.. 
P45,602; and Mike Noe, Reg. No. 44,975. 

Send correspondence to: Andrew J. Dillon, FELSMAN, BRADLEY, VADEN, GUNTER & 
DILLON, LLP, Lakewood on the Park, Suite 350, 7600B North Capital of Texas 
Highway, Austin, Texas 78731, and direct all telephone calls to Andrew J. Dillon, 
512/343-6116. 



FULL NAME OF SOLE OR FIRST INVENTOR :>^ Daniel O tto Becker 

INVENTORS SIGNATURE :_ 

RES IDENCE : 10909 Grapevine Lane 

Austin, Texas 78759 ^ 

CITIZENSHIP: U.S.A. 

POST OFFICE ADDRESS: same 
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